package com.jin.gulimall.order;


import com.jin.gulimall.order.entity.OrderReturnReasonEntity;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.amqp.rabbit.annotation.RabbitHandler;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

import java.util.Date;

/**
 * 使用RabbitMQ
 * 1.引入amqp场景  RabbitAutoConfiguration就会自动生效
 * 2.给容器中自动配置了
 *   RabbitTemplate、AmqpAdmin、CachingConnectionFactory、RabbitMessagingTemplate
 *   所有属性都是 spring.rabbitmq
 *  @ConfigurationProperties(prefix = "spring.rabbitmq")
 *   public class RabbitProperties {
 * 3.给配置文件中配置 spring.rabbitmq 信息
 * 4. @EnableRabbit; @EnableXxxx;开启功能
 * 5.监听消息：@RabbitListener,只要是监听消息就要有@EnableRabbit注解
 * @RabbitListener 标在类+方法上(监听哪些消息即可)
 * @RabbitHandler 标在方法上(重载区分不同的消息)
 *
 *  本地事务失效问题
 *  同一个对象内事务方法互调默认失效，原因：绕过了代理对象，事务使用代理对象来控制
 *  解决：
 *    (1)、引入aop-starter;spring-boot-starter-aop;引入了aspectj
 *    (2)、@EnableAspectJAutoProxy(exposeProxy=true);开启aspectj动态代理功能。
 *        以后所有的动态代理都是aspectj创建的(即使没有接口)
 *    (3)、本类互调调用对象
 *    OrderServiceImpl orderService = (OrderServiceImpl)AopContext.currentProxy();
 *       orderService.b();
 *       orderService.a();
 * Seata控制分布式事务
 * 1.每一个微服务先必须创建 undo_log;回滚日志
 * 2.安装事务协调器； seata-server: https://github.com/seata/seata/releases
 * 3.整合
 *    1>.导入依赖 spring-cloud-starter-alibaba-seata   seata-all-0.7.1
 *    2>.解压并启动seata-server;
 *         registry.conf:注册中心配置；修改 registry type=nacos
 *         file.conf
 *    3>.所有想要用到分布式事务的微服务使用seata DataSourceProxy代理自己的数据源
 *    4>.每个微服务，都必须导入 registry.conf file.conf
 *    vgroup_mapping.{application.name}-fescar-service-group = "default"
 *    5>.启动测试分布式事务
 *    6>.给分布式大事务的入口标注@GlobalTransactional
 *    7>.每一个远程的小事务用@Transactional
 *
 */
@EnableAspectJAutoProxy(exposeProxy = true)
@EnableFeignClients
@EnableRedisHttpSession
@EnableDiscoveryClient
@EnableRabbit
@MapperScan("com.jin.gulimall.order.dao")
@SpringBootApplication
public class GulimallOrderApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallOrderApplication.class, args);
    }
}
